package com.acme.bankapp.domain.bank;


public class Client 
{	
	private String name;

	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + ((account == null) ? 0 : account.hashCode());
		result = prime * result + ((gender == null) ? 0 : gender.hashCode());
		result = prime * result + ((name == null) ? 0 : name.hashCode());
		return result;
	}

	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		Client other = (Client) obj;
		if (account == null) {
			if (other.account != null)
				return false;
		} else if (!account.equals(other.account))
			return false;
		if (gender.equals(other.gender))
			return false;
		if (name == null) {
			if (other.name != null)
				return false;
		} else if (!name.equals(other.name))
			return false;
		return true;
	}

	public String getName() {
		return name;
	}	
	
	@Override
	public String toString() {		
		StringBuffer sbuffer = new StringBuffer();
		sbuffer.append("Client [name=" + gender + name + "]");
		sbuffer.append("[account=" + account + "]");
		return sbuffer.toString();
	}

	private Gender gender;
	
	public String getClientSalutation() {
        // XXX [MY] This dead (unused) code should be removed. - this code isn't unused, it is used to get client's name only (e.g. in listeners)
		return gender.toString()+name;
	}
	
	private Account account;

	public Account getAccount() {
		return account;
	}

	public Client(String name, Gender gender, Account account) {
		this.name = name;
		this.gender = gender;
		this.account = account;
	}	
	
}
